<template>
	<el-dialog :title="titleMap[mode]" v-model="visible" :width="1000" destroy-on-close @closed="$emit('closed')" align-center>
		<el-form :model="form" :rules="rules" :disabled="mode == 'show'" ref="dialogForm" label-width="110px" label-position="right">
            <el-col>
                <el-form-item label="头像" prop="avatar">
                    <sc-upload v-model="form.avatar" title="上传头像"></sc-upload>
                </el-form-item>
            </el-col>
            <el-row :gutter="1">
                <el-col :span="12">
                    <el-form-item label="登录手机号" prop="account">
                        <el-input v-model="form.account" placeholder="用于登录系统" clearable autocomplete="off"></el-input>
                    </el-form-item>
                </el-col>
                <el-col :span="12">
                    <el-form-item label="姓名" prop="name">
                        <el-input v-model="form.name" placeholder="请输入完整的真实姓名" clearable></el-input>
                    </el-form-item>
                </el-col>
            </el-row>
            <el-row :gutter="1">
                    <el-col :span="12">
                        <el-form-item label="登录密码" prop="password">
                            <el-input type="password" v-model="form.password" clearable show-password autocomplete="new-password"></el-input>
                        </el-form-item>
                    </el-col>
                    <el-col :span="12">
                        <el-form-item label="确认密码" prop="password_confirm">
                            <el-input type="password" v-model="form.password_confirm" clearable show-password autocomplete="new-password"></el-input>
                        </el-form-item>
                    </el-col>
            </el-row>
            <el-row :gutter="1">
                <el-col :span="12">
                    <el-form-item label="所属部门" prop="dept_id">
                        <el-cascader v-model="form.dept_id" :options="depts" :props="deptsProps" clearable style="width: 100%;" filterable></el-cascader>
                    </el-form-item>
                </el-col>
                <el-col :span="12">
                    <el-form-item label="所属岗位" prop="jobs_id">
                        <el-select v-model="form.jobs_id" multiple filterable style="width: 100%" clearable>
                            <el-option v-for="item in jobs" :key="item.id" :label="item.name" :value="item.id" />
                        </el-select>
                    </el-form-item>
                </el-col>
            </el-row>
            <el-row :gutter="1">
                <el-col :span="12">
                    <!-- <el-form-item label="状态" prop="disable">
                        <el-switch v-model="form.disable" :active-value="0" :inactive-value="1"></el-switch>
                    </el-form-item> -->
                    <el-form-item label="入职时间" prop="entry_date">
                        <el-date-picker v-model="form.entry_date" :value-format="'YYYY-MM-DD'" style="width:100%" type="date" placeholder="请选择交期时间" />
                    </el-form-item>
                </el-col>

                <el-col :span="12">
                    <!-- <el-form-item label="多处登录" prop="multipoint_login">
                        <el-switch v-model="form.multipoint_login" :active-value="1" :inactive-value="0"></el-switch>
                    </el-form-item> -->
                    <el-form-item label="薪资结算方式" prop="settlement_method">
                        <el-select v-model="form.settlement_method"  filterable placeholder="请选择品牌" style="width:100%" clearable @change="change">
                            <el-option label="计时" :value="1"/>
                            <el-option label="计件" :value="2"/>
                            <el-option label="计时+计件" :value="3"/>
                        </el-select>
                    </el-form-item>
                </el-col>
            </el-row>
            <el-row :gutter="1">
                <el-col :span="12">
                    <el-form-item label="收款银行" prop="bank_name">
                        <el-input v-model="form.bank_name" placeholder="请输入银行" clearable autocomplete="off"></el-input>
                    </el-form-item>
                </el-col>
                <el-col :span="12">
                    <el-form-item label="银行卡号" prop="bank_card">
                        <el-input v-model="form.bank_card" placeholder="请输入银行卡号" clearable></el-input>
                    </el-form-item>
                </el-col>
            </el-row>
            <div class="title">工资结算方式</div>
            <!-- 计件 -->
            <el-row :gutter="1" v-if="monryType==2">
                <el-col :span="8">
                    <el-form-item label="底薪" prop="basic_salary">
                        <el-input v-model="form.basic_salary" type="number" placeholder="底薪"></el-input>
                    </el-form-item>
                </el-col>
                <el-col :span="8">
                    <el-form-item label="房补" prop="housing_allowance_money">
                        <el-input v-model="form.housing_allowance_money" type="number" placeholder="房补"></el-input>
                    </el-form-item>
                </el-col>
                <el-col :span="8">
                    <el-form-item label="餐补" prop="meal_allowance_money">
                        <el-input v-model="form.meal_allowance_money" type="number" placeholder="餐补"></el-input>
                    </el-form-item>
                </el-col>
                <!-- <el-col :span="6">
                    <el-form-item label="初版" prop="first_edition_money">
                        <el-input v-model="form.first_edition_money" type="number" placeholder="初版"><template #append>元/件</template></el-input>
                    </el-form-item>
                </el-col>
                <el-col :span="6">
                    <el-form-item label="修改版" prop="retouching_edition_money">
                        <el-input v-model="form.retouching_edition_money" type="number" placeholder="修改版"><template #append>元/件</template></el-input>
                    </el-form-item>
                </el-col>
                <el-col :span="6">
                    <el-form-item label="放码" prop="release_code_money">
                        <el-input v-model="form.release_code_money" type="number" placeholder="放码"><template #append>元/款</template></el-input>
                    </el-form-item>
                </el-col> -->
            </el-row>
            <el-row :gutter="1" v-if="monryType==2">
                <el-col :span="8">
                    <el-form-item label="大货提成" prop="dahuo_commission_money">
                        <el-input v-model="form.dahuo_commission_money" type="number" placeholder="大货提成"><template #append>元/件</template></el-input>
                    </el-form-item>
                </el-col>
            </el-row>
            <!-- 计时 -->
            <el-row :gutter="1" v-if="monryType==1">
                <el-col :span="8">
                    <el-form-item label="底薪" prop="basic_salary">
                        <el-input v-model="form.basic_salary" type="number" placeholder="底薪"></el-input>
                    </el-form-item>
                </el-col>
                <el-col :span="8">
                    <el-form-item label="正班工资" prop="regular_work_money">
                        <el-input v-model="form.regular_work_money" type="number" placeholder="初版"><template #append>元/时</template></el-input>
                    </el-form-item>
                </el-col>
                <el-col :span="8">
                    <el-form-item label="加班工资" prop="overtime_work_money">
                        <el-input v-model="form.overtime_work_money" type="number" placeholder="修改版"><template #append>元/时</template></el-input>
                    </el-form-item>
                </el-col>
            </el-row>
            <el-row :gutter="1" v-if="monryType==1">
                <el-col :span="8">
                    <el-form-item label="房补" prop="housing_allowance_money">
                        <el-input v-model="form.housing_allowance_money" type="number" placeholder="房补"></el-input>
                    </el-form-item>
                </el-col>
                <el-col :span="8">
                    <el-form-item label="餐补" prop="meal_allowance_money">
                        <el-input v-model="form.meal_allowance_money" type="number" placeholder="餐补"></el-input>
                    </el-form-item>
                </el-col>
            </el-row>
            <!-- 计时 +  计件-->
            <el-row :gutter="1" v-if="monryType==3">
                <el-col :span="8">
                    <el-form-item label="底薪" prop="basic_salary">
                        <el-input v-model="form.basic_salary" type="number" placeholder="底薪"></el-input>
                    </el-form-item>
                </el-col>
                <el-col :span="8">
                    <el-form-item label="正班工资" prop="regular_work_money">
                        <el-input v-model="form.regular_work_money" type="number" placeholder="初版"><template #append>元/时</template></el-input>
                    </el-form-item>
                </el-col>
                <el-col :span="8">
                    <el-form-item label="加班工资" prop="overtime_work_money">
                        <el-input v-model="form.overtime_work_money" type="number" placeholder="修改版"><template #append>元/时</template></el-input>
                    </el-form-item>
                </el-col>
            </el-row>
            <el-row :gutter="1">
                <el-col :span="8">
                    <el-form-item label="初版" prop="first_edition_money">
                        <el-input v-model="form.first_edition_money" type="number" placeholder="初版"><template #append>元/件</template></el-input>
                    </el-form-item>
                </el-col>
                <el-col :span="8">
                    <el-form-item label="修改版" prop="retouching_edition_money">
                        <el-input v-model="form.retouching_edition_money" type="number" placeholder="修改版"><template #append>元/件</template></el-input>
                    </el-form-item>
                </el-col>
                <el-col :span="8">
                    <el-form-item label="放码" prop="release_code_money">
                        <el-input v-model="form.release_code_money" type="number" placeholder="放码"><template #append>元/款</template></el-input>
                    </el-form-item>
                </el-col>
            </el-row>
            <el-row :gutter="1" v-if="monryType==3">
                <el-col :span="8">
                    <el-form-item label="大货提成" prop="dahuo_commission_money">
                        <el-input v-model="form.dahuo_commission_money" type="number" placeholder="大货提成"><template #append>元/件</template></el-input>
                    </el-form-item>
                </el-col>
                <el-col :span="8">
                    <el-form-item label="房补" prop="housing_allowance_money">
                        <el-input v-model="form.housing_allowance_money" type="number" placeholder="房补"></el-input>
                    </el-form-item>
                </el-col>
                <el-col :span="8">
                    <el-form-item label="餐补" prop="meal_allowance_money">
                        <el-input v-model="form.meal_allowance_money" type="number" placeholder="餐补"></el-input>
                    </el-form-item>
                </el-col>
            </el-row>
            <el-row :gutter="1">
                <el-col :span="12">
                    <el-form-item label="状态" prop="disable">
                        <el-switch v-model="form.disable" :active-value="0" :inactive-value="1"></el-switch>
                    </el-form-item>
                </el-col>
                <el-col :span="12">
                    <el-form-item label="多处登录" prop="multipoint_login">
                        <el-switch v-model="form.multipoint_login" :active-value="1" :inactive-value="0"></el-switch>
                    </el-form-item>
                </el-col>
            </el-row>
		</el-form>
		<template #footer>
			<el-button @click="visible = false">取 消</el-button>
			<el-button v-if="mode != 'show'" type="primary" :loading="isSaveing" @click="submit()">保 存</el-button>
		</template>
	</el-dialog>
</template>

<script>
export default {
	emits: ['success', 'closed'],
	data() {
		return {
			mode: "add",
			titleMap: {
				add: '新增员工',
				edit: '编辑员工',
				show: '查看'
			},
			visible: false,
			isSaveing: false,
			//表单数据
			form: {
				id: "",
				account: "",
				avatar: "",
				name: "",
				dept_id: "",
				jobs_id: [],
				disable: 0,
                entry_date:"",
                bank_name:"",
                bank_card:"",
                settlement_method:"",
				multipoint_login: 1,
                password:"",
                password_confirm:"",
                basic_salary:"",//底薪
                regular_work_money:"",//正班时间
                overtime_work_money:"",//加班工时
                housing_allowance_money:"",//房补
                meal_allowance_money:"",//餐补
                first_edition_money:"",//初版
                retouching_edition_money:"",//修改版
                release_code_money:"",//放码
                dahuo_commission_money:"",//大货提成
                has_piece_money:"",//大货提成
			},
            monryType:"",
			//验证规则
			rules: {
				account: [
					{ required: true, message: '请输入登录账号' }
				],
				name: [
					{ required: true, message: '请输入真实姓名' }
				],
				password: [
					{ required: true, message: '请输入登录密码' },
					{
						validator: (rule, value, callback) => {
							if (this.form.password_confirm !== '') {
								this.$refs.dialogForm.validateField('password_confirm');
							}
							callback();
						}
					}
				],
				password_confirm: [
					{ required: true, message: '请再次输入密码' },
					{
						validator: (rule, value, callback) => {
							if (value !== this.form.password_confirm) {
								callback(new Error('两次输入密码不一致!'));
							} else {
								callback();
							}
						}
					}
				],
				jobs_id: [
					{ required: true, message: '请选择所属岗位' }
				],
				dept: [
					{ required: true, message: '请选择所属部门' }
				],
				group: [
					{ required: true, message: '请选择所属角色', trigger: 'change' }
				]
			},
			//所需数据选项
			roles: [],
			rolesProps: {
				value: "id",
				multiple: true,
				checkStrictly: true
			},
			depts: [],
			deptsProps: {
				value: "id",
				checkStrictly: true
			},
			jobs: [],
			jobsProps: {
				value: "id",
				checkStrictly: true
			},
		}
	},
	mounted() {
		this.getGroup()
		this.getDept()
		this.getJobs()
	},
	methods: {
		//显示
		open(mode = 'add') {
			this.mode = mode;
			this.visible = true;
			return this
		},
		//加载树数据
		async getGroup() {
			var res = await this.$API.system.role.list.get();
			this.roles = res.data.rows;
		},
		async getDept() {
			var res = await this.$API.system.dept.list.get();
			this.depts = res.data;
		},
		async getJobs() {
			var res = await this.$API.system.jobs.list.get();
			this.jobs = res.data;
		},
		//表单提交方法
		submit() {
			this.$refs.dialogForm.validate(async (valid) => {
				if (valid) {
					this.isSaveing = true;
					var res = [];
					if (this.form.id) {
						res = await this.$API.setting.staff.edit.post(this.form);
					} else {
						res = await this.$API.setting.staff.add.post(this.form);
					}
					this.isSaveing = false;
					if (res.code == 1) {
						this.$emit('success', this.form, this.mode)
						this.visible = false;
						this.$message.success("操作成功")
					} else {
						this.$alert(res.message, "提示", { type: 'error' })
					}
				} else {
					return false;
				}
			})
		},
		//表单注入数据
		setData(data) {
			this.form.id = data.id
			this.form.account = data.account
			this.form.avatar = data.avatar
			this.form.name = data.name
			this.form.role_id = data.role_id
			this.form.dept_id = data.dept_id
			this.form.jobs_id = data.jobs_id
			this.form.bank_name = data.bank_name
			this.form.bank_card = data.bank_card
			this.form.disable = data.disable
			this.form.multipoint_login = data.multipoint_login
			this.form.entry_date = data.entry_date
			this.form.settlement_method = data.settlement_method
			this.monryType = data.settlement_method
			this.form.basic_salary = data.salary.basic_salary
			this.form.regular_work_money = data.salary.regular_work_money
			this.form.overtime_work_money = data.salary.overtime_work_money
			this.form.housing_allowance_money = data.salary.housing_allowance_money
			this.form.meal_allowance_money = data.salary.meal_allowance_money
			this.form.first_edition_money = data.salary.first_edition_money
			this.form.retouching_edition_money = data.salary.retouching_edition_money
			this.form.release_code_money = data.salary.release_code_money
			this.form.dahuo_commission_money = data.salary.dahuo_commission_money
			this.form.has_piece_money = data.salary.has_piece_money
            const isEdit = this.mode=='edit';
            if (isEdit) {
                this.rules.password = [];
                this.rules.password_confirm = [];
            }
		},
        change(e){
            this.monryType = e
            this.form.basic_salary = "" 
			this.form.regular_work_money = "" 
			this.form.overtime_work_money = "" 
			this.form.housing_allowance_money = "" 
			this.form.meal_allowance_money = "" 
			this.form.first_edition_money = "" 
			this.form.retouching_edition_money = "" 
			this.form.release_code_money = "" 
			this.form.dahuo_commission_money = "" 
			this.form.has_piece_money = "" 
        },
	}
}
</script>

<style>
.el-input-group__append{
    padding: 0 6px;
}
</style>
